# **Date:8/13/24**

# 

# **EE488 - Computer Architecture**

# **Final exam**

**NAME : S A SABBIRUL MOHOSIN NAIM**

**ID : 20176**

**Question ans : 01**

.data

prompt: .asciiz "Enter an integer: "

result\_msg: .asciiz "The two's complement is: "

.text

.globl main

main:

# Print the prompt message

li $v0, 4 # syscall for print\_string

la $a0, prompt # load address of the prompt message

syscall

# Read an integer from the user

li $v0, 5 # syscall for read\_int

syscall

move $t0, $v0 # store the input integer in $t0

# Calculate two's complement

# Two's complement: invert the bits and add 1

not $t1, $t0 # invert the bits of the input integer

addi $t1, $t1, 1 # add 1 to get two's complement

# Print the result message

li $v0, 4 # syscall for print\_string

la $a0, result\_msg # load address of the result message

syscall

# Print the two's complement integer

move $a0, $t1 # move the two's complement to $a0 for printing

li $v0, 1 # syscall for print\_int

syscall

# Exit program

li $v0, 10 # syscall for exit

syscall

**Question ans : 02**

.data

prompt: .asciiz "Enter an integer: "

newline: .asciiz "\n"

star: .asciiz "\*"

.text

.globl main

main:

# Print the prompt message

li $v0, 4

la $a0, prompt

syscall

# Read an integer from the user

li $v0, 5

syscall

move $t0, $v0 # move the read integer to $t0

# Outer loop for each line of the triangle

li $t1, 1 # initialize line counter to 1

line\_loop:

ble $t1, $t0, process\_line # continue if line counter is less than or equal to input

j end\_program

process\_line:

# Inner loop to print stars in each line

li $t2, 0 # initialize star counter to 0

star\_loop:

li $v0, 4

la $a0, star

syscall

addi $t2, $t2, 1 # increment star counter

blt $t2, $t1, star\_loop # continue if star counter is less than line counter

# Print newline after finishing line of stars

li $v0, 4

la $a0, newline

syscall

addi $t1, $t1, 1 # increment line counter

j line\_loop # jump back to the start of line\_loop

end\_program:

# Exit program

li $v0, 10

syscall

**Question ans : 03**

To design an effective Program Counter (PC) for a 32-bit machine, several key considerations need to be taken into account. Here's a description of an effective method to design the PC:

**1. 32-bit Register:**

- The PC should be implemented as a 32-bit register to match the machine's architecture.

- This allows addressing of up to 4GB of memory (2^32 bytes).

**2. Initialization:**

- The PC should be initialized to the starting address of the program when execution begins.

- Typically, this is done by loading a predetermined value (e.g., 0x00000000) at system reset.

**3. Increment Logic:**

- In most cases, the PC should automatically increment by 4 after each instruction fetch.

- This is because in a 32-bit machine, instructions are typically 4 bytes (32 bits) long.

- Implement an adder that adds 4 to the current PC value.

**4. Branch and Jump Support:**

- Include logic to handle non-sequential execution flows like branches and jumps.

- For conditional branches, implement a multiplexer to select between PC+4 and the branch target address.

- For jumps, allow direct loading of the jump target address into the PC.

**5. Pipeline Considerations:**

- In a pipelined processor, the PC should be updated at the beginning of each clock cycle.

- Implement logic to handle pipeline stalls and flushes, ensuring the PC maintains the correct value.

**6. Exception Handling:**

- Include mechanisms to save the current PC value when an exception occurs.

- Provide a way to load the PC with the address of the appropriate exception handler.

**7. Memory Interface:**

- Ensure the PC can interface with the instruction memory or cache.

- Implement proper timing and control signals for memory access.

**8. Clock Synchronization:**

- The PC should be updated synchronously with the processor's clock.

- Use edge-triggered flip-flops to maintain stability and prevent timing issues.

**9. Power Efficiency:**

- Implement clock gating to reduce power consumption when the processor is idle.

**10. Testability:**

- Include scan chain support for testing purposes.

- Implement debug features like the ability to read and write the PC value directly.

**11. Byte Addressing:**

- Ensure the PC increments and addresses memory correctly, considering that memory is byte-addressable but instructions are word-aligned.

**12. Modularity:**

- Design the PC as a separate module with clear interfaces to other processor components.

- This allows for easier testing, modification, and potential reuse in different designs.

By incorporating these features, the PC design will be effective for a 32-bit machine, providing accurate instruction sequencing, supporting various control flow mechanisms, and integrating well with other processor components. This design ensures efficient program execution while maintaining flexibility for different types of instructions and addressing modes.

**Question ans : 04**

While it's theoretically possible to execute an instruction in a single cycle, modern processor architectures predominantly use multiple-cycle datapaths for several important reasons. Let's explore these reasons in detail:

**1. Clock Speed Limitations:**

- In a single-cycle design, the clock period must be long enough to accommodate the slowest instruction.

- This severely limits the overall clock speed of the processor, as faster instructions are forced to wait.

- Multiple-cycle designs allow for higher clock speeds by breaking operations into smaller steps.

**2. Complex Instructions:**

- Modern instruction sets often include complex operations (e.g., floating-point calculations, SIMD instructions).

- These complex instructions would require an extremely long cycle time if implemented in a single cycle.

- Multiple cycles allow these operations to be broken down into manageable steps.

**3. Memory Access Latency:**

- Memory operations, especially those involving cache misses or external memory, can take significantly longer than simple ALU operations.

- A single-cycle design would need to accommodate the worst-case memory access time for every instruction.

- Multiple cycles allow memory operations to be split across cycles, with stalling mechanisms for longer operations.

**4. Power Efficiency:**

- Single-cycle designs require all components to be active for every instruction, even if not all are used.

- Multi-cycle designs allow for more granular power management, activating only necessary components in each cycle.

- This leads to significant power savings, crucial for modern processors, especially in mobile devices.

**5. Pipelining Benefits:**

- Multiple-cycle designs naturally lend themselves to pipelining, where different stages of multiple instructions can be executed simultaneously.

- This dramatically increases throughput without requiring a proportional increase in hardware.

- Pipelining is a key feature in almost all modern processors for performance enhancement.

**6. Resource Sharing:**

- Multi-cycle designs allow for efficient sharing of hardware resources among different instruction types.

- For example, the same ALU can be used for arithmetic in one cycle and address calculation in another.

- This leads to more efficient use of chip area and reduced complexity.

**7. Timing and Synchronization:**

- Breaking operations into multiple cycles makes it easier to manage timing and synchronization issues.

- It allows for the insertion of pipeline registers, which help in maintaining signal integrity and reducing clock skew.

**8. Instruction-Level Parallelism:**

- Multiple-cycle designs, especially when pipelined, allow for instruction-level parallelism.

- This means parts of multiple instructions can be executed simultaneously, increasing overall throughput.

**9. Easier Design and Verification:**

- Dividing instruction execution into multiple stages simplifies the design and verification process.

- It's easier to isolate and debug issues in smaller, discrete stages than in a complex single-cycle design.

**10. Flexibility for Different Instruction Types:**

- Different types of instructions can take different numbers of cycles as needed.

- This allows for a more efficient balance between simple and complex instructions.

**11. Support for Advanced Features:**

- Multiple-cycle designs better support advanced features like out-of-order execution, speculative execution, and branch prediction.

- These features significantly enhance performance but require complex control logic that's difficult to implement in a single cycle.

**12. Scalability:**

- Multi-cycle designs are more scalable, allowing for easier implementation of more complex instruction sets and architectural improvements over time.

In conclusion, while single-cycle execution is theoretically possible, the practical limitations in terms of performance, efficiency, and functionality make multiple-cycle datapaths the preferred choice in modern processor architectures. The benefits of increased clock speed, better resource utilization, power efficiency, and support for advanced features far outweigh the theoretical simplicity of a single-cycle design.

**Question ans : 05**

Designing the control functional block for a multiple cycle datapath in processor architecture requires careful planning and implementation. The goal is to correctly sequence the execution of each part of the instruction through the datapath across multiple cycles. Here, I will outline the steps for designing control signals and also provide a conceptual diagram.

**Key Components of Control Signals:**

**1. Instruction Fetch (IF):**

- IRWrite: Loads the fetched instruction into the instruction register.

- PCWrite: Updates the program counter to point to the next instruction.

- PCWriteCond: Conditionally updates the program counter for branch instructions.

- PCSource: Determines the source of the next program counter value (sequential, branch, or jump).

**2. Instruction Decode (ID):**

- Control Signal Generation: Based on the opcode and function fields of the instruction, generate signals to control the rest of the processor operations.

**3. Execution (EX):**

- ALUOp: Specifies the operation the ALU should perform.

- ALUSrc: Determines the second operand of the ALU (from registers or immediate).

- RegDst: Selects the register destination (for R-type instructions).

**4. Memory Access (MEM):**

- MemRead: Enables reading from memory (for load instructions).

- MemWrite: Enables writing to memory (for store instructions).

- Branch: Determines whether a branch should be taken.

**5. Write Back (WB):**

- RegWrite: Enables writing to the register file.

- MemtoReg: Determines whether the value to write comes from memory or the ALU.

**Control Signal Generation:**

Control signals are typically generated by a finite state machine (FSM) or a microprogrammed control unit that outputs the appropriate signals based on the current instruction type and state of execution. The control unit uses the opcode and function codes from the instruction to generate these signals.

**Diagram Concept:**

Here’s a simplified conceptual diagram that might represent how control signals interact with a multiple cycle datapath.

![](data:image/png;base64,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1/2KX4yJIkSABPRzAqrcQj1GBkhg3mT2XkcVWoRIGCMDJECIlF2ESBgjAyRAiJRdhEgYIwMkQIiUXYRIGCMDJECIlF2ESBgjAyRAiJRdhEgYIwMkQIiUXYRIGCMDJECIlF2ESBgjAyRAiJRdhEgYIwMkQIiUXYRIGCMDJECIlF2ESBgjAyRAiJRdhEgYIwMkQIiUXYRIGCMDJECIlF2ESBgjAyRAiJRdhEgYIwMkQIiUXYRIGCMDJECIlF2ESBgjAyRAiJRdhEgYIwMkQIiUXYRIGCMDJECIlF2ESBgjAyRAiJRdhEgYIwMkQIiUXYRIGCMDJECIlF2ESBgjAyRAiJRdhEgYIwMk0HeIPLX7quptJx4/L/lalp1z+rurjY2NLcte/7qjqs0rzt+yjisv2D6/v/yr6zzt1JOr/TdftuW+y0oeI+vxpetdp+qOb8giRMIYGSCBvkNESpr3G487ZtH0tZnb0PD3WVZN7rvqcXXLmhQhkg9GBkhgiBDRKw95xS/NWpq2vQrQZdLQtSm/9U3b5iVBc+7v/sbivrouG0J16/T7IFUXGP4KqG799vF6m4aGDxG9T2gfui5CJIyRARIYIkSkEUtDlgatb019dsf7FsFhb9embBu4fzvLhoFv4j4UbPkQ0cfqMnmMBJd8rcFk12vv5/dX6pJPfmi+n7Lcb7uvIkTCGBkggSFCxF5paDO+9/qLtzRfCQkfCvL4ZSFiG7rcpt/XXQnEfiZir0ZkPw7ccvn8X3m8X6fur96/7j59FiESxsgACQwRIv4tKn/VcOopJwWvLOTxy0JEb/NVdzXgr0SkNDDsVZJsW+6j+7FnFngagn6dPkRCV0F9FSESxsgACQwRIlL21b02eBsAGhpNQ8RfiSyruhCxjw+9TaZXInaftOxbYrJ/sq66sOmrCJEwRgZIYKgQsYGhYaBvc8kybbxNQ8Tfv8lnIlIabrJu+1h7VeLXa9+e89uXZaHt91GESBgjAyQwVIjoK37bxO1bQRoQvinLMh8iPpBsGNn7+Qp9JqJXMXY9sq/bjj36sP21j9f98/trA8Zvv48iRMIYGSCBoUKE6qcIkTBGBkiAECm7CJEwRgZIgBApuwiRMEYGSIAQKbsIkTBGBkiAECm7CJEwRgZIgBApuwiRMEYGSIAQKbsIkTBGBkiAECm7CJEwRgZIgBApuwiRMEYGSIAQKbsIkTBGBkiAECm7CJEwRgZIgBApuwiRMEYGSIAQKbsIkTBGBkiAECm7CJEwRgZIgBApuwiRMEYGSIAQKbsIkTBGBkiAECm7CJEwRgZIgBApuwiRMEYGSIAQKbsIkTBGBkiAECm7CJEwRgZIgBApuwiRMEYGSIAQKbsIkTBGBkiAECm7CJEwRgZIgBApuwiRMEYGSIAQKbsIkTBGBkiAECm7CJEwRgZIQJoMVXah3v8HJMIyLZ2V1k4AAAAASUVORK5CYII=)

**Implementing the FSM Control:**

**1. State Transitions:**

- Each major operation phase (Fetch, Decode, Execute, Memory, Write Back) is represented as a state in the FSM.

- Transitions between states are based on the completion of the required actions in each state.

**2. Generating Control Signals:**

- In the fetch state, `PCWrite` and `IRWrite` are asserted.

- In the decode state, signals like `ALUSrc`, `ALUOp`, and `RegDst` are set based on decoding the instruction.

- Execute, Memory Access, and Write Back states assert specific controls based on the instruction type (load, store, arithmetic, etc.).

This approach of using an FSM to generate control signals ensures that each stage of the instruction execution pipeline is correctly managed and timed, which is critical for maintaining correct operation and high performance in a multiple cycle datapath.

**Advanced Implementations:**

For more complex processors, control units might also integrate elements like branch prediction and out-of-order execution logic, which further complicates the control signal logic but improves overall efficiency and speed. These elements would typically be represented as additional blocks or layers in the control unit diagram.

**Question ans : 06**

Let's analyze the five-stage pipelining architecture for the given scenario and calculate the instruction execution latency and throughput.

Given:

- 5 pipeline stages: Fetch, Decode, Execute, Memory, and Writeback

- 6 instructions: 3 R-types and 3 I-types

- Clock frequency: 1 GHz (1 clock cycle = 1 ns)

**Instruction Execution Latency:**

The latency is the time it takes for a single instruction to complete all five stages.

Latency = Number of stages × Clock cycle time

= 5 stages × 1 ns/stage

= 5 ns per instruction

**Throughput:**

In an ideal pipeline without stalls or hazards, once the pipeline is full, we complete one instruction per clock cycle.

Throughput = Number of instructions / Time period

= 1 instruction / 1 ns

= 1 instruction per ns

For 10 ns:

Throughput (per 10 ns) = 10 instructions

**Pipeline Execution:**

Let's visualize the execution of the 6 instructions over time:

**Clock Cycle: 1 2 3 4 5 6 7 8 9 10**

Instruction 1: **F D E M W**

Instruction 2:  **F D E M W**

Instruction 3: **F D E M W**

Instruction 4: **F D E M W**

Instruction 5:  **F D E M W**

Instruction 6:  **F D E M W**

```

F: Fetch, D: Decode, E: Execute, M: Memory, W: Writeback

**Analysis:**

- The first instruction takes 5 cycles to complete (5 ns latency).

- From the 5th cycle onward, one instruction completes every cycle.

- By the 10th cycle, 6 instructions have been fetched, and 5 have completed.

**Actual Throughput for this scenario:**

In 10 ns, 5 instructions have completed fully.

Actual Throughput (per 10 ns) = 5 instructions

**Conclusion:**

1. Instruction Execution Latency: 5 ns per instruction

2. Theoretical Throughput (per 10 ns): 10 instructions

Actual Throughput for given 6 instructions (per 10 ns): 5 instructions

3. The difference between theoretical and actual throughput is due to the initial pipeline fill time. In a continuous stream of instructions, the throughput would approach the theoretical maximum of 1 instruction per ns.

4. The type of instructions (R-type or I-type) doesn't affect the latency or throughput in this ideal scenario, assuming no data hazards or structural hazards. In a real processor, different instruction types might have different execution times or resource requirements, potentially affecting the pipeline efficiency.

5. This analysis assumes an ideal scenario without pipeline stalls, branch mispredictions, or data hazards. In real-world scenarios, these factors would reduce the actual throughput and increase average latency.

**Question ans : 07**

To address varying instruction lengths between R-type and load instructions while avoiding structural hazards in a pipelined processor design, several methods can be employed. Let's explore these design approaches:

**1. Uniform Pipeline Stage Duration:**

- Design all pipeline stages to have the same duration, based on the longest instruction type.

- Pro: Simplifies pipeline control and avoids structural hazards.

- Con: May introduce unnecessary delays for shorter instructions.

**2. Multiple-Cycle Execution Stage:**

- Allow the Execute stage to take multiple cycles for complex instructions.

- Use a completion signal to indicate when the instruction is ready to move to the next stage.

- Pro: Accommodates varying instruction lengths without slowing down simpler instructions.

- Con: Requires more complex control logic.

**3. Parallel Functional Units:**

- Implement separate functional units for different instruction types (e.g., ALU for R-type, address calculation unit for loads).

- Allow instructions to use the appropriate unit without conflict.

- Pro: Improves throughput and avoids structural hazards.

- Con: Increases hardware complexity and cost.

**4. Instruction Queues:**

- Implement instruction queues between pipeline stages.

- Allow faster instructions to proceed while slower ones are still executing.

- Pro: Improves overall pipeline efficiency.

- Con: Requires additional hardware and control logic.

**5. Dynamic Scheduling:**

- Implement out-of-order execution with techniques like Tomasulo's algorithm.

- Allow instructions to execute as soon as their operands are ready, regardless of program order.

- Pro: Maximizes resource utilization and handles varying instruction lengths effectively.

- Con: Significantly increases design complexity.

**6. Pipeline Interlocking:**

- Implement a mechanism to stall the pipeline when a long-latency instruction is detected.

- Resume normal operation once the instruction completes.

- Pro: Simple to implement and effective at preventing hazards.

- Con: Can lead to performance penalties due to frequent stalls.

**7. Instruction Predecoding:**

- Add a predecode stage that quickly determines instruction type and potential resource needs.

- Use this information to guide instruction routing and scheduling.

- Pro: Allows for more informed decision-making in later stages.

- Con: Adds an extra pipeline stage, potentially increasing latency.

**8. Resource Reservation:**

- Implement a reservation system where instructions "book" required resources in advance.

- Stall or reroute instructions if resources are unavailable.

- Pro: Prevents structural hazards by ensuring resource availability.

- Con: Requires additional control logic and may introduce delays.

**9. Superscalar Architecture:**

- Implement multiple execution units that can handle different instruction types simultaneously.

- Use instruction dispatch logic to route instructions to appropriate units.

- Pro: Significantly improves throughput for mixed instruction types.

- Con: Increases design complexity and hardware cost.

**10. Variable-Length Pipeline:**

- Design a pipeline with a variable number of stages based on instruction type.

- Use bypass paths for shorter instructions to skip unnecessary stages.

- Pro: Optimizes execution time for each instruction type.

- Con: Complicates pipeline control and hazard detection.

**11. Micro-operation Decomposition:**

- Break down complex instructions into simpler micro-operations.

- Execute these micro-ops through a uniform pipeline.

- Pro: Simplifies pipeline design and execution.

- Con: May increase the total number of pipeline stages for complex instructions.

**Implementation Strategy:**

To effectively implement these methods:

1. Analyze the instruction set to identify varying length instructions.

2. Determine the frequency and impact of each instruction type.

3. Choose a combination of methods that best fits the processor's design goals (performance, power efficiency, chip area, etc.).

4. Implement robust hazard detection and resolution mechanisms.

5. Use simulation and benchmarking to validate the design and optimize performance.

By carefully applying these design methods,we can create a pipelined processor that efficiently handles varying instruction lengths while minimizing structural hazards, leading to improved overall performance and resource utilization.